//给定两个数组 nums1 和 nums2 ，返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。
//
//
//
// 示例 1：
//
//
//输入：nums1 = [1,2,2,1], nums2 = [2,2]
//输出：[2]
//
//
// 示例 2：
//
//
//输入：nums1 = [4,9,5], nums2 = [9,4,9,8,4]
//输出：[9,4]
//解释：[4,9] 也是可通过的
//
//
//
//
// 提示：
//
//
// 1 <= nums1.length, nums2.length <= 1000
// 0 <= nums1[i], nums2[i] <= 1000
//
//
// Related Topics 数组与矩阵 哈希表 双指针 二分查找 排序 👍 755 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
function intersection(nums1: number[], nums2: number[]): number[] {

    let set = new Set()
    let nums : number[]
    let find : number[]
    nums1.length > nums2.length ? nums = nums2: nums = nums1
    nums1.length > nums2.length ? find = nums1: find = nums2
    for (let i = 0; i < Math.min(nums1.length, nums2.length); i++) {
        if (find.indexOf(nums[i]) !== -1) {
            if (!set.has(nums[i])) {
                set.add(nums[i])
            }
        }
    }
    return Array.from(set) as number[]
};
//leetcode submit region end(Prohibit modification and deletion)
